<template>
  <view>
    <!-- 预留出的搜索区域 -->
    <MySearch></MySearch>

    <view class="scroll-view-container">
      <!-- 左侧的滚动区域 -->
      <scroll-view
        class="left-scroll-view"
        scroll-y
        :style="{ height: wh + 'px' }"
      >
        <!-- active -->
        <block v-for="(item1, index) in categoryList" :key="index">
          <view
            class="left-scroll-view-item"
            @click="selectCategoryHandler(index)"
            :class="{ active: selectedCategory === index }"
          >
            {{ item1.cat_name }}
          </view>
        </block>
      </scroll-view>

      <!-- 右侧的滚动区域 -->
      <!-- 
        scroll-top 属性 只能单向设置给视图  数据驱动视图  
           如果页面滚动了 是不会更新数据scrollTop!!!
       -->
      <scroll-view
        class="right-scroll-view"
        scroll-y
        :style="{ height: wh + 'px' }"
        :scroll-top="scrollTop"
      >
        <!-- 动态渲染二级分类的列表数据 -->
        <view
          class="cate-lv2"
          v-for="(item2, index2) in categoryList[selectedCategory].children"
          :key="index2"
        >
          <view class="cate-lv2-title">/ {{ item2.cat_name }} /</view>

          <!-- 三级分类的渲染  item2.children -->
          <!-- 动态渲染三级分类的列表数据 -->
          <view class="cate-lv3-list">
            <view
              @click="goToProductList(item3)"
              class="cate-lv3-item"
              v-for="(item3, index3) in item2.children"
              :key="index3"
            >
              <image :src="item3.cat_icon"></image>
              <text>{{ item3.cat_name }}</text>
            </view>
          </view>
        </view>
      </scroll-view>
    </view>
  </view>
</template>

<script>
import MySearch from '@/components/my-search.vue'

export default {
  data() {
    return {
      wh: 0,
      // 1. 分类数据数组
      categoryList: [],
      // 当前选中项的索引，默认让第一项被选中
      selectedCategory: 0,

      scrollTop: 0,
    }
  },

  components: {
    MySearch,
  },

  created() {
    // 动态获取窗口可用高度，以便让页面中的左右两块滚动区域的高度撑满屏幕
    // 1. 获取当前系统信息
    const sysInfo = uni.getSystemInfoSync()

    console.log(sysInfo)

    // 2. 从系统信息中获取窗口可用高度并赋值给 wh
    // 窗口的可用高度 = 屏幕高度 - navigationBar高度 - tabBar高度
    this.wh = sysInfo.windowHeight - 50 // 减去拟搜索框的高度

    this.getCategoryList()
  },

  methods: {
    // 3. 定义获取分类数据的方法
    async getCategoryList() {
      const { meta, message } = await this.$http.get('/categories')

      // 请求失败处理
      if (meta.status !== 200) {
        return this.$msg()
      }

      this.categoryList = message
    },

    selectCategoryHandler(index) {
      this.selectedCategory = index

      /* 
        数据没有变

        vue框架 高效更新页面的机制   数据驱动视图  数据变了 视图自动变化  只有数据变了 视图才会更新
      */

      this.scrollTop = this.scrollTop === 0 ? 1 : 0 // 重置滚动条(滚动条回到顶部)
    },

    goToProductList(item3) {
      // console.log(item3.cat_id)

      uni.navigateTo({
        url: '/pages_sub1/product-list/product-list?cid=' + item3.cat_id,
      })
    },
  },
}
</script>

<style scoped lang="scss">
.scroll-view-container {
  display: flex;

  .left-scroll-view {
    width: 240rpx;

    .left-scroll-view-item {
      line-height: 120rpx;
      background-color: #f7f7f7;
      text-align: center;
      font-size: 24rpx;

      // 激活项的样式
      &.active {
        background-color: #ffffff;
        position: relative;

        // 渲染激活项左侧的红色指示边线
        &::before {
          content: ' ';
          display: block;
          width: 6rpx;
          height: 60rpx;
          background-color: #c00000;
          position: absolute;
          left: 0;
          top: 50%;
          transform: translateY(-50%);
        }
      }
    }
  }
}

.cate-lv2-title {
  font-size: 24rpx;
  font-weight: bold;
  text-align: center;
  padding: 30rpx 0;
}

.cate-lv3-list {
  display: flex;
  flex-wrap: wrap;

  .cate-lv3-item {
    width: 33.33%;
    margin-bottom: 20rpx;
    display: flex;
    flex-direction: column;
    align-items: center;

    image {
      width: 120rpx;
      height: 120rpx;
    }

    text {
      font-size: 24rpx;
    }
  }
}
</style>
